草庐IT

MongoDb 查询 - 计数 + where 条件

全部标签

ruby-on-rails - Rails 3. 使用 Formtastic 有条件地显示字段

我正在使用ActiveAdmin和Formtastic。我有一张发票表格,其中包含发货下拉菜单。formdo|f|f.inputs"ShipmentDetails"dof.input:shipment_id,:label=>"Shipment",:as=>:select,:collection=>Shipment.find(invoiceless_shipments,:order=>"file_number",:select=>"id,file_number").map{|v|[v.file_number,v.id]}f.input:issued_at,:label=>"Date",:

ruby-on-rails - Development.log 日志文件不记录 Rails SQL 查询

我在这里关注MichaelHartl的Rails教程:http://ruby.railstutorial.org/chapters/modeling-and-viewing-users-one#top我使用此命令在单独的窗口中跟踪SQL查询:tail-flog/development.log然而,当我在沙盒Rails控制台中时,日志不会用SQL语句更新,而是显示在Rails控制台中。我该如何纠正这种行为?我应该补充一点,我的数据库迁移和对数据模型(新表等)的更改都反射(reflect)在日志中。仅省略由Rails控制台内的方法传播的SQL语句(而是显示在Rails控制台中)。这是我的G

ruby-on-rails - 关系 belongs_to 上的 activerecord where 子句

我不太擅长sql,对Rails也比较陌生。Caseattr_accessibleclient_idbelongs_toClientClientattr_accessibenamehas_manyCases我可以直接通过client_id查询,并按预期取回一条记录Case.where(client_id:1)但是我想通过client.name查询Case.where(client.name=>"Foo")这给我一个错误,告诉我client不是case的方法。Undefinedmethodorlocalvariable最终,我要做的非常简单:获取属于客户“Foo”的第一个案例。我希望使用的

ruby-on-rails - Ruby Gem ActiveRecord 具有多个条件的查找方法

我正在使用三个数据库表构建一个Sinatra应用程序:user、post和like。我想运行一个查询来在like表中找到一个条目,如下所示:FINDinlikeWHEREuser_id==params[:user_id]ANDpost_id==params[:post_id](对于一种情况,我将使用:Like.find_by_user_id(params[:user_id]))我的问题是:如何使用ActiveRecordGem运行具有多个条件的查找查询? 最佳答案 使用where:Like.where('user_id=?ANDpo

ruby - 我如何在逻辑上或两个包括? ruby 的条件?

我刚开始学习Ruby,需要一些关于include的帮助吗?方法。下面的代码工作得很好:x='ab.c'ifx.include?"."puts'hello'elseputs'no'end但是当我这样编码时:x='ab.c'y='xyz'ifx.include?"."||y.include?"."puts'hello'elseputs'no'end如果在运行时出现错误:test.rb:3:syntaxerror,unexpectedtSTRING_BEG,expectingkeyword_thenor';'or'\n'ifx.include?"."||y.include?"."^test.

ruby - 如果值不为零,有条件地在 Ruby 中执行 block ? (又名 Smalltalk 的 ifNotNilDo :)

在Smalltalk中有方法ifNotNilDo:它是这样使用的:databasegetUserifNotNilDo:[:user|MailsendTo:user]在不是nil的对象上执行block,将对象本身作为参数传递。UndefinedObject类(Smalltalk等同于Ruby的NilClass)中的实现什么也不做。这样,如果获取用户的结果是nil对象,则什么也不会发生。我不知道Ruby有类似的东西,所以我推出了自己的解决方案。它是这样的:classObjectdefnot_nilyield(self)endendclassNilClassdefnot_nil#donoth

ruby - 如何在 ActiveRecord 中执行 LIKE % 查询?

我正在尝试查找一些包含特定字符串的项目。如果我这样做:MyModel.where("descriptionLIKE?",keyword)它将生成一个完全匹配的查询。我想让它生成一个LIKE%keyword%查询。我该怎么做? 最佳答案 like_keyword="%#{keyword}%"MyModel.where("descriptionLIKE?",like_keyword) 关于ruby-如何在ActiveRecord中执行LIKE%查询?,我们在StackOverflow上找到一

ruby-on-rails - 两个表上的 Rails where 子句

我在rails应用程序中有以下模型category=>company=>storeStore有一个belongs_to公司,company有一个belongs_to类别关系。现在我想在商店对象上使用where方法来检索同一类别中的所有商店。我想要这样的东西@stores.nearbys(5).where("stores.company.category_id=xxx")谁能给我一些建议 最佳答案 尝试用连接表上的where连接:@stores.nearbys(5).joins(:company).where("companies.c

ruby - `map` 基于条件

我有一个这样的结构:Struct.new("Test",:loc,:type,:hostname,:ip)clients=[Struct::TestClient.new(1,:pc,"pc1","192.168.0.1")Struct::TestClient.new(1,:pc,"pc2","192.168.0.2")Struct::TestClient.new(1,:tablet,"tablet1","192.168.0.3")Struct::TestClient.new(1,:tablet,"tablet2","192.168.0.3")andetc...]如果我想获取所有设备的I

ruby - 为什么 Ruby 中没有竞争条件

我正在试验多线程示例。我正在尝试使用以下代码产生竞争条件。但我总是得到相同(正确)的输出。classCounterattr_reader:countdefinitialize@count=0enddefincrement@count+=1enddefdecrement@count-=1endendc=Counter.newt1=Thread.start{100_0000.times{c.increment}}t2=Thread.start{100_0000.times{c.increment}}t1.joint2.joinpc.count#200_0000我能够在每个线程中使用更少的迭